<script setup lang="ts">
import AddWrite from './components/addWrite.vue'
import { ContentDetailWrap } from '@/components/ContentDetailWrap'
import { ref, unref } from 'vue'
import { ElButton } from 'element-plus'
import { useI18n } from '@/hooks/web/useI18n'
import { useRouter, useRoute } from 'vue-router'
import { repertoryEdit, repertoryDetail } from '@/api/common'
import { storageType } from '@/api/common/types'
import { TableData } from '@/api/table/types'
import { useEmitt } from '@/hooks/web/useEmitt'

const { emitter } = useEmitt()

const { push } = useRouter()

const { query } = useRoute()

const { t } = useI18n()

const currentRow = ref<Nullable<TableData>>(null)

const getTableDet = async () => {
  const res = await repertoryDetail(query.id as string)
  if (res) {
    console.log('---获取row内容---')
    currentRow.value = res.data
  }
}

getTableDet()

const addWriteRef = ref<ComponentRef<typeof AddWrite>>()

const loading = ref(false)

const save = async () => {
  const write = unref(addWriteRef)
  console.log('---addWrite---', write?.getFormData())
  const data = {
    // id: write?.getFormData()?.id,
    // goods_id: write?.getFormData()?.goods_id,
    // store_id: write?.getFormData()?.store_id,
    // transport: write?.getFormData()?.transport,
    // placestart: write?.getFormData()?.placestart,
    // client_code: write?.getFormData()?.client_code,
    // remark: write?.getFormData()?.remark,
    // piece: write?.getFormData()?.piece,
    // entrytime: write?.getFormData()?.entrytime,
    // goods: write?.getFormData()?.goods,
    // shouhuo: write?.getFormData()?.shouhuo,
    length: write?.getFormData()?.length,
    width: write?.getFormData()?.width,
    high: write?.getFormData()?.high,
    weight: write?.getFormData()?.weight
  } as storageType
  console.log('---采购单编辑参数---', data)
  const res = await repertoryEdit(data, write?.getFormData()?.id)
  if (res) {
    emitter.emit('getList', 'edit')
    push('/warehouseManagement/warehouseManagement')
  }
}
</script>

<template>
  <ContentDetailWrap :title="t('exampleDemo.edit')" @back="push('/logistics/warehouseManagement')">
    <!-- <Write ref="addWriteRef" :current-row="currentRow" /> -->
    <AddWrite ref="addWriteRef" :current-row="currentRow" />

    <template #right>
      <ElButton type="primary" :loading="loading" @click="save">
        {{ t('exampleDemo.save') }}
      </ElButton>
    </template>
  </ContentDetailWrap>
</template>
